#! /usr/bin/bash

# Copyright (c) 2023. Huawei Technologies Co.,Ltd.ALL rights reserved.
# This program is licensed under Mulan PSL v2.
# You can use it according to the terms and conditions of the Mulan PSL v2.
#          http://license.coscl.org.cn/MulanPSL2
# THIS PROGRAM IS PROVIDED ON AN "AS IS" BASIS, WITHOUT WARRANTIES OF ANY KIND,
# EITHER EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO NON-INFRINGEMENT,
# MERCHANTABILITY OR FIT FOR A PARTICULAR PURPOSE.
# See the Mulan PSL v2 for more details.

# #############################################
# @Author    :   deepin12
# @Contact   :   chenyia@uniontech.com
# @Date      :   2023-11-30
# @License   :   Mulan PSL v2
# @Desc      :   Command test-autrace
# ############################################

source "${OET_PATH}"/libs/locallibs/common_lib.sh

function pre_test() {
    LOG_INFO "Start environment preparation."
    OLD_LANG=$LANG
    export LANG=en_US.UTF-8    
    auditctl -l > audit_rules.bak
    auditctl -D
    LOG_INFO "End of environmental preparation!"
}

function run_test() {
    LOG_INFO "Start to run test."
    autrace -r /bin/ls /root|grep ausearch    
    CHECK_RESULT $? 0 0 "file write failure"
    pid=$(autrace -r /bin/ls /root 2>&1 | grep -Po 'ausearch -i -p \K[0-9]+')
    CHECK_RESULT $? 0 0 "load rule failure"
    ausearch -i -p "$pid" |grep ls
    CHECK_RESULT $? 0 0 "rule write failure"
    LOG_INFO "End to run test."
}

function post_test() {
    LOG_INFO "Start to clean the test environment."
    export LANG=${OLD_LANG}
    auditctl -R audit_rules.bak
    rm -f audit_rules.bak
    LOG_INFO "End to clean the test environment."
}

main "$@"
